## MIPS32® Instruction Set Quick Reference

 $\begin{array}{lll} R_D & & - & D_{\text{ESTINATION REGISTER}} \\ R_S,\,R_T & & - & Source \; \text{operand registers} \\ R_A & & - & R_{\text{ETURN ADDRESS REGISTER}} \; (R31) \end{array}$ 

PC — PROGRAM COUNTER
ACC — 64-BIT ACCUMULATOR

Lo, Hi — Accumulator low (Acc31:0) and high (Acc63:32) parts

± − Signed operand or sign extension

Ø − Unsigned operand or zero extension

∴ − Concatenation of bit fields

R2 − MIPS32 Release 2 instruction

DOTTED − ASSEMBLER PSEUDO-INSTRUCTION

PLEASE REFER TO "MIPS32 ARCHITECTURE FOR PROGRAMMERS VOLUME II: THE MIPS32 INSTRUCTION SET" FOR COMPLETE INSTRUCTION SET INFORMATION.

| Arithmetic Operations |                                                               |                                           |
|-----------------------|---------------------------------------------------------------|-------------------------------------------|
| ADD                   | Rd, Rs, Rt                                                    | $R_D = R_S + R_T$ (overflow trap)         |
| ADDI                  | ADDI RD, Rs, const16 $RD = Rs + const16^{\pm}$ (overflow traf |                                           |
| ADDIU                 | Rd, Rs, const16                                               | $R_D = R_S + const 16^{\pm}$              |
| ADDU                  | Rd, Rs, Rt                                                    | $R_D = R_S + R_T$                         |
| CLO                   | RD, RS                                                        | $R_D = C_{OUNT}L_{EADING}O_{NES}(R_S)$    |
| CLZ                   | RD, RS                                                        | $R_D = C_{OUNT} L_{EADING} Z_{EROS}(R_S)$ |
| LA                    | Rd, label                                                     | $R_D = A_{DDRESS(LABEL)}$                 |
| LI                    | Rd, imm32                                                     | $R_D = I_{MM}32$                          |
| LUI                   | Rd, const16                                                   | $R_D = CONST 16 \ll 16$                   |
| MOVE                  | RD, Rs                                                        | $R_D = R_S$                               |
| NEGU                  | RD, Rs                                                        | $R_D = -R_S$                              |
| $SEB^{R2}$            | Rd, Rs                                                        | $R_D = R_{S7:0}^{\pm}$                    |
| SEH <sup>R2</sup>     | RD, Rs                                                        | $R_D = R_{S_{15:0}}^{\pm}$                |
| SUB                   | Rd, Rs, Rt                                                    | $R_D = R_S - R_T$ (OVERFLOW TRAP)         |
| SUBU                  | Rd, Rs, Rt                                                    | $R_D = R_S - R_T$                         |

| Shift and Rotate Operations |                |                                               |
|-----------------------------|----------------|-----------------------------------------------|
| ROTR <sup>R2</sup>          | Rd, Rs, bits5  | $R_D = R_{S_{BITS5-1:0}} :: R_{S_{31:BITS5}}$ |
| ROTRV <sup>R2</sup>         | RD, Rs, RT     | $R_D = R_{S_{RT4:0-1:0}} :: R_{S_{31:RT4:0}}$ |
| SLL                         | Rd, Rs, shift5 | $R_D = R_S << shift 5$                        |
| SLLV                        | Rd, Rs, Rt     | $R_D = R_S << R_{T_{4:0}}$                    |
| SRA                         | Rd, Rs, shift5 | $R_D = R_S^{\pm} >> _{SHIFT}5$                |
| SRAV                        | Rd, Rs, Rt     | $R_D = R_{S^{\pm}} >> R_{T_{4:0}}$            |
| SRL                         | Rd, Rs, shift5 | $R_D = R_S^{\varnothing} >> SHIFT5$           |
| SRLV                        | Rd, Rs, Rt     | $R_D = R_S^{\varnothing} >> R_{T_{4:0}}$      |

|                    | Logical and Bit-Field Operations |                                                                       |  |
|--------------------|----------------------------------|-----------------------------------------------------------------------|--|
| AND                | Rd, Rs, Rt                       | $R_D = R_S \& R_T$                                                    |  |
| ANDI               | Rd, Rs, const16                  | $R_D = R_S \& const 16^{\varnothing}$                                 |  |
| EXT <sup>R2</sup>  | RD, Rs, P, S                     | $R_S = R_{S_{P+S-1:P}}^{\varnothing}$                                 |  |
| INS <sup>R2</sup>  | RD, Rs, P, S                     | $R_{D_{P+S-1:P}} = R_{S_{S-1:0}}$                                     |  |
| NOP                |                                  | No-ор                                                                 |  |
| NOR                | Rd, Rs, Rt                       | $R_D = \sim (R_S \mid R_T)$                                           |  |
| NOT                | RD, RS                           | $R_D = \sim R_S$                                                      |  |
| OR                 | Rd, Rs, Rt                       | $R_D = R_S \mid R_T$                                                  |  |
| ORI                | Rd, Rs, const16                  | $R_D = R_S \mid \text{const} 16^{\varnothing}$                        |  |
| WSBH <sup>R2</sup> | RD, RS                           | $R_D = R_{S_{23:16}} :: R_{S_{31:24}} :: R_{S_{7:0}} :: R_{S_{15:8}}$ |  |
| XOR                | Rd, Rs, Rt                       | $R_D = R_S \oplus R_T$                                                |  |
| XORI               | Rd, Rs, const16                  | $R_D = R_S \oplus const16^{\varnothing}$                              |  |

| (     | CONDITION TESTING AND CONDITIONAL MOVE OPERATIONS |                                                                                                  |  |
|-------|---------------------------------------------------|--------------------------------------------------------------------------------------------------|--|
| MOVN  | Rd, Rs, Rt                                        | IF $R_T \neq 0$ , $R_D = R_S$                                                                    |  |
| MOVZ  | Rd, Rs, Rt                                        | $_{\mathrm{IF}}$ $\mathrm{R}_{\mathrm{T}}=0$ , $\mathrm{R}_{\mathrm{D}}=\mathrm{R}_{\mathrm{S}}$ |  |
| SLT   | Rd, Rs, Rt                                        | $R_D = (R_S^{\pm} < R_T^{\pm}) ? 1 : 0$                                                          |  |
| SLTI  | Rd, Rs, const16                                   | $R_D = (R_S^{\pm} < CONST 16^{\pm}) ? 1 : 0$                                                     |  |
| SLTIU | Rd, Rs, const16                                   | $R_D = (R_S^{\varnothing} < \text{const} 16^{\varnothing}) ? 1 : 0$                              |  |
| SLTU  | Rd, Rs, Rt                                        | $R_D = (R_S^{\varnothing} < R_T^{\varnothing}) ? 1 : 0$                                          |  |

|       | Multiply and Divide Operations |                                                                                               |  |
|-------|--------------------------------|-----------------------------------------------------------------------------------------------|--|
| DIV   | Rs, Rt                         | $L_0 = R_S^{\pm} / R_T^{\pm}$ ; $H_I = R_S^{\pm} \mod R_T^{\pm}$                              |  |
| DIVU  | Rs, Rt                         | $L_0 = R_S^{\varnothing} / R_T^{\varnothing}; H_I = R_S^{\varnothing} \mod R_T^{\varnothing}$ |  |
| MADD  | Rs, Rt                         | $A_{CC} += R_S^{\pm} \times R_T^{\pm}$                                                        |  |
| MADDU | Rs, Rt                         | $Acc += Rs^{\varnothing} \times Rt^{\varnothing}$                                             |  |
| MSUB  | Rs, Rt                         | $Acc = Rs^{\pm} \times Rt^{\pm}$                                                              |  |
| MSUBU | Rs, Rt                         | $Acc = Rs^{\varnothing} \times Rt^{\varnothing}$                                              |  |
| MUL   | Rd, Rs, Rt                     | $R_D = R_{S^{\pm}} \times R_{T^{\pm}}$                                                        |  |
| MULT  | Rs, Rt                         | $A_{CC} = Rs^{\pm} \times R_{T}^{\pm}$                                                        |  |
| MULTU | Rs, Rt                         | $Acc = Rs^{\varnothing} \times Rt^{\varnothing}$                                              |  |

| ACCUMULATOR ACCESS OPERATIONS |    |             |
|-------------------------------|----|-------------|
| MFHI                          | RD | $R_D = H_I$ |
| MFLO                          | RD | $R_D = L_O$ |
| MTHI                          | Rs | $H_I = R_S$ |
| MTLO                          | Rs | Lo = Rs     |

|        | Jumps And Branches (Note: One Delay Slot) |                                                                      |  |
|--------|-------------------------------------------|----------------------------------------------------------------------|--|
| B      | OFF18                                     | PC += OFF18 <sup>±</sup>                                             |  |
| BAL    | OFF18                                     | $R_A = PC + 8$ , $PC += OFF18^{\pm}$                                 |  |
| BEQ    | Rs, Rt, off18                             | $_{\rm IF}$ $R_{\rm S}$ = $R_{\rm T}$ , $PC$ += $_{\rm OFF}18^{\pm}$ |  |
| BEQZ   | Rs, off18                                 | $_{\rm IF}$ R <sub>S</sub> = 0, PC += $_{\rm OFF}18^{\pm}$           |  |
| BGEZ   | Rs, off18                                 | IF Rs $\geq 0$ , PC += OFF18 <sup>±</sup>                            |  |
| BGEZAL | Rs, off18                                 | $R_A = PC + 8$ ; IF $R_S \ge 0$ , $PC += OFF18^{\pm}$                |  |
| BGTZ   | Rs, off18                                 | $_{\rm IF}$ Rs > 0, PC += $_{\rm OFF}18^{\pm}$                       |  |
| BLEZ   | Rs, off18                                 | IF $Rs \le 0$ , $PC += OFF18^{\pm}$                                  |  |
| BLTZ   | Rs, off18                                 | $_{\rm IF}  {\rm R}_{\rm S} < 0,  {\rm PC}  + = _{\rm OFF} 18^{\pm}$ |  |
| BLTZAL | Rs, off18                                 | $R_A = PC + 8$ ; IF $R_S < 0$ , $PC += OFF18^{\pm}$                  |  |
| BNE    | Rs, Rt, off18                             | IF Rs $\neq$ RT, PC $+=$ OFF $18^{\pm}$                              |  |
| BNEZ   | Rs, off18                                 | IF Rs $\neq$ 0, PC += OFF18 <sup>±</sup>                             |  |
| J      | ADDR28                                    | $PC = PC_{31:28} :: ADDR28^{\varnothing}$                            |  |
| JAL    | ADDR28                                    | $R_A = PC + 8$ ; $PC = PC_{31:28} :: ADDR28^{\emptyset}$             |  |
| JALR   | Rd, Rs                                    | $R_D = PC + 8$ ; $PC = R_S$                                          |  |
| JR     | Rs                                        | PC = Rs                                                              |  |

|     | Load and Store Operations |                                                                             |  |
|-----|---------------------------|-----------------------------------------------------------------------------|--|
| LB  | Rd, off16(Rs)             | $R_D = _{MEM}8(R_S + _{OFF}16^{\pm})^{\pm}$                                 |  |
| LBU | Rd, off16(Rs)             | $R_{\rm D} = {}_{\rm MEM}8(R_{\rm S} + {}_{\rm OFF}16^{\pm})^{\varnothing}$ |  |
| LH  | Rd, off16(Rs)             | $R_D = _{MEM}16(R_S + _{OFF}16^{\pm})^{\pm}$                                |  |
| LHU | Rd, off16(Rs)             | $R_{\rm D} = _{\rm MEM} 16 (R_{\rm S} + _{\rm OFF} 16^{\pm})^{\varnothing}$ |  |
| LW  | Rd, off16(Rs)             | $R_D = _{\text{MEM}} 32(R_S + _{\text{OFF}} 16^{\pm})$                      |  |
| LWL | Rd, off16(Rs)             | $R_D = L_{OAD}W_{ORD}L_{EFT}(R_S + off16^{\pm})$                            |  |
| LWR | Rd, off16(Rs)             | $R_D = L_{OAD}W_{ORD}R_{IGHT}(R_S + off 16^{\pm})$                          |  |
| SB  | Rs, off16(Rt)             | $MEM8(RT + OFF16^{\pm}) = RS_{7:0}$                                         |  |
| SH  | Rs, off16(Rt)             | $_{\text{MEM}}16(R_{\text{T}} + _{\text{OFF}}16^{\pm}) = R_{S_{15:0}}$      |  |
| SW  | Rs, off16(Rt)             | $MEM32(RT + OFF16^{\pm}) = Rs$                                              |  |
| SWL | Rs, off16(Rt)             | STOREWORDLEFT(RT + OFF 16 <sup>±</sup> , Rs)                                |  |
| SWR | Rs, off16(Rt)             | STOREWORDRIGHT(RT + OFF 16 <sup>±</sup> , Rs)                               |  |
| ULW | Rd, off16(Rs)             | $R_D = UNALIGNED\_MEM32(R_S + OFF16^{\pm})$                                 |  |
| USW | Rs, off16(Rt)             | $UNALIGNED\_MEM32(R_T + OFF16^{\pm}) = R_S$                                 |  |

| Atomic Read-Modify-Write Operations                     |               |                                                                  |  |
|---------------------------------------------------------|---------------|------------------------------------------------------------------|--|
| LL RD, OFF16(Rs) $R_D = MEM32(Rs + OFF16^{\pm})$ ; LINK |               |                                                                  |  |
| SC                                                      | Rd, off16(Rs) | if Atomic, mem32(Rs + off16 $^{\pm}$ ) = Rd; Rd = Atomic ? 1 : 0 |  |

|       | Registers |                                               |  |
|-------|-----------|-----------------------------------------------|--|
| 0     | zero      | Always equal to zero                          |  |
| 1     | at        | Assembler temporary; used by the assembler    |  |
| 2-3   | v0-v1     | Return value from a function call             |  |
| 4-7   | a0-a3     | First four parameters for a function call     |  |
| 8-15  | t0-t7     | Temporary variables; need not be preserved    |  |
| 16-23 | s0-s7     | Function variables; must be preserved         |  |
| 24-25 | t8-t9     | Two more temporary variables                  |  |
| 26-27 | k0-k1     | Kernel use registers; may change unexpectedly |  |
| 28    | gp        | Global pointer                                |  |
| 29    | sp        | Stack pointer                                 |  |
| 30    | fp/s8     | Stack frame pointer or subroutine variable    |  |
| 31    | ra        | Return address of the last subroutine call    |  |

### Default C Calling Convention (032)

### Stack Management

- · The stack grows down.
- Subtract from \$sp to allocate local storage space.
- Restore \$sp by adding the same amount at function exit.
- The stack must be 8-byte aligned.
- · Modify \$sp only in multiples of eight.

### **Function Parameters**

- Every parameter smaller than 32 bits is promoted to 32 bits.
- First four parameters are passed in registers \$a0-\$a3.
- 64-bit parameters are passed in register pairs:
  - Little-endian mode: \$a1:\$a0 or \$a3:\$a2.
  - Big-endian mode: \$a0:\$a1 or \$a2:\$a3.
- Every subsequent parameter is passed through the stack.
- First 16 bytes on the stack are not used.
- Assuming \$sp was not modified at function entry:
  - The 1<sup>st</sup> stack parameter is located at 16(\$sp).
  - The 2<sup>nd</sup> stack parameter is located at 20(\$sp), etc.
- 64-bit parameters are 8-byte aligned.

### **Return Values**

- 32-bit and smaller values are returned in register \$v0.
- 64-bit values are returned in registers \$v0 and \$v1:
- Little-endian mode: \$v1:\$v0.
- Big-endian mode: \$v0:\$v1.

| MIPS32 Virtual Address Space |             |             |          |          |
|------------------------------|-------------|-------------|----------|----------|
| kseg3                        | 0xE000.0000 | 0xFFFF.FFFF | Mapped   | Cached   |
| ksseg                        | 0xC000.0000 | 0xDFFF.FFFF | Mapped   | Cached   |
| kseg1                        | 0xA000.0000 | 0xBFFF.FFFF | Unmapped | Uncached |
| kseg0                        | 0x8000.0000 | 0x9FFF.FFFF | Unmapped | Cached   |
| useg                         | 0x0000.0000 | 0x7FFF.FFFF | Mapped   | Cached   |

## unsigned mips\_cycle\_counter\_read() { unsigned cc; asm volatile("mfc0 %0, \$9" : "=r" (cc)); return (cc << 1); }</pre>

```
ASSEMBLY-LANGUAGE FUNCTION EXAMPLE
# int asm max(int a, int b)
   int r = (a < b) ? b : a;
   return r;
# }
    .text
    .set
             nomacro
             noreorder
    .set
    .global asm max
    .ent
             asm max
asm max:
             $v0, $a0
    move
                             \# r = a
    slt
             $t0, $a0, $a1 # a < b ?
    jr
             $ra
                             # return
    movn
             $v0, $a1, $t0 # if yes, r = b
    end
             asm max
```

# #include <stdio.h> int asm\_max(int a, int b); int main() { int x = asm\_max(10, 100); int y = asm\_max(200, 20); printf("%d %d\n", x, y); }

```
int dp(int a[], int b[], int n)
{
   int i;
   long long acc = (long long) a[0] * b[0];
   for (i = 1; i < n; i++)
       acc += (long long) a[i] * b[i];
   return (acc >> 31);
}
```

INVOKING MULT AND MADD INSTRUCTIONS FROM C

```
atomic_inc:

11 $t0, 0($a0) # load linked addiu $t1, $t0, 1 # increment $c $t1, 0($a0) # store cond'l beqz $t1, atomic_inc # loop if failed nop
```

```
Accessing Unaligned Data
  NOTE: ULW AND USW AUTOMATICALLY GENERATE APPROPRIATE CODE
     LITTLE-ENDIAN MODE
                                     BIG-ENDIAN MODE
LWR
                              LWL
         RD, OFF16(Rs)
                                       RD, OFF16(Rs)
LWL
         RD. OFF16+3(Rs)
                             LWR
                                       RD. OFF16+3(Rs)
SWR
         RD, OFF16(Rs)
                              SWL
                                       RD, OFF16(Rs)
SWL
         RD, OFF16+3(Rs)
                              SWR
                                       RD, OFF16+3(Rs)
```

```
typedef struct
{
   int u;
} __attribute__((packed)) unaligned;

int unaligned_load(void *ptr)
{
   unaligned *uptr = (unaligned *)ptr;
   return uptr->u;
}
```

| MIPS SDE-GCC Compiler Defines |                                        |  |
|-------------------------------|----------------------------------------|--|
| mips                          | MIPS ISA (= 32 for MIPS32)             |  |
| mips_isa_rev                  | MIPS ISA Revision (= 2 for MIPS32 R2)  |  |
| mips_dsp                      | DSP ASE extensions enabled             |  |
| _MIPSEB                       | Big-endian target CPU                  |  |
| _MIPSEL                       | Little-endian target CPU               |  |
| _MIPS_ARCH_CPU                | Target CPU specified by -march=CPU     |  |
| _MIPS_TUNE_CPU                | Pipeline tuning selected by -mtune=CPU |  |

### Notes

- Many assembler pseudo-instructions and some rarely used machine instructions are omitted.
- The C calling convention is simplified. Additional rules apply when passing complex data structures as function parameters.
- The examples illustrate syntax used by GCC compilers.
- Most MIPS processors increment the cycle counter every other cycle. Please check your processor documentation.